有没有办法让在64位系统上运行的32位应用程序访问64位应用程序的默认文件夹?例如,在32位应用程序中将SHGetSpecialFolderPath与CSIDL_PROGRAM_FILES结合使用会返回“C:\从32位应用程序获取“C:\ProgramFiles”的方法?这里的一个相关问题没有帮助SHGetFolderPath()32bitvs64bit在调用SHGetSpecialFolderPath之前也不会抑制wow64文件系统重定向 最佳答案 回答我自己的问题,SHGetSpecialFolderPath似乎是不可能的。在V
有时在我的OpenGL应用程序中,我会在以下API调用中遇到访问冲突:wglMakeCurrent(NULL,NULL);应用程序只有一个线程,我在那个调用之前检查过,当前使用的DC和HGLRC都是正确有效的。有OpenGL内容的三个不同窗口,如果由于用户交互(例如,拾取对象)而需要刷新,它们都会根据WM_PAINT消息重绘。此外,这种访问冲突发生在具有不同显卡的不同机器上,所以我认为这不是驱动程序问题。什么会导致此API调用崩溃?我应该在应用程序代码中调查什么以找出发生这种情况的位置/原因?我真的迷路了,因为我已经检查了我能想到的一切。我希望有人可以给我一些提示/想法,告诉我还需要检
我可以HookWindows7中的哪些用户模式函数来监视/拦截文件访问?我试过ntdll.dll的NtOpenFile()、NtCreateFile(),但其中一些不是文件——它们也是管道和互斥锁。kernel32.dll的CreateFile()也是如此。是否有仅调用以访问文件/目录的函数。如果有帮助,我试图只Hookexplorer.exe以防止访问firefox.exe。我也在使用EasyHook,如果你们熟悉的话。我想我也曾在某处读到过,使用NtOpenFile/NtCreateFile的参数,您可以区分文件访问/管道访问。但这仍然有点模糊。有没有好用的hook函数?编辑:请记
我想从系统访问远程系统中存在的COM端口。任何帮助将不胜感激。我在远程和本地系统中都使用WindowsXP。 最佳答案 com0com项目,尤其是com2tcp应用程序应该可以帮助您。InconjunctionwiththeNull-modememulator(com0com)thecom2tcpenablestouseaCOMportbasedapplicationstocommunicatewiththeTCP/IPbasedapplications.Italsoallowscommunicationwitharemoteser
我想从Java获取WindowsXP/Vista/7中“打开方式...”上下文菜单的列表。从Windows注册表中,我设法找到了一种方法来获取启动应用程序的命令。但是我没有找到如何获取这些应用程序的名称和图标,如资源管理器打开列表上下文菜单中所示。此外,管理这些信息的方式似乎从一个操作系统版本到另一个版本。是否有任何库可以用于Java?谢谢。 最佳答案 您不需要注册表。您需要在Shell32.dll中的OpenAs_RunDLLA上使用GetProcAddress。我找不到它的任何文档,但我有将其定义为的Delphi代码SHOpen
在用户的网络浏览器中打开URL非常简单:ShellExecuteA(NULL,"open",url,NULL,NULL,SW_SHOWNORMAL);我应该调用什么来使用给定的URL从网站检索数据?在Mac上,我会使用:URLSimpleDownload(url,NULL,newDataH,0,NULL,NULL);它存储在newDataH中处理从url检索到的数据。很容易。在Windows上是否有等效项? 最佳答案 您可能正在寻找WinINet中的InternetReadFile函数.以下是该API中常用函数的一个很好的列表:Co
我想更改新创建的远程线程的堆栈,但在调用CreateRemoteThread创建处于挂起状态的线程时,堆栈尚未分配。我在创建挂起线程后使用GetThreadContext获取ESP的地址,但如果我在VS调试器的反汇编窗口中查看此地址,它尚未分配。此外,每次使用WriteProcessMemory写入此地址都会失败。如何编辑新创建但挂起的远程线程的堆栈? 最佳答案 当你获得线程句柄时,它的堆栈被分配,(以及TIB结构)。MSVS调试器可能会显示错误信息,所以不要依赖它。我不确定线程上下文是否有正确的值,也许是稍后设置的。你应该使用
深入研究与TIB(线程信息block)一起工作的Win32API函数的实现,例如:TLS访问函数:TlsAlloc、TlsFree、TlsSetValue、TlsGetValueGetLastError,SetLastError消息子系统:GetMessage、PeekMessage等通过读取fs:[0x18]选择器的内容,我们发现它们都访问了TIB,有时称为TEB(线程环境block)。OTOH这是不必要的,因为fs寄存器直接指向它。根据thisarticle我在实践中看到的是,fs寄存器保存了TIB结构开头的地址,而在偏移量0x18处它有一个指向自身的指针。间接访问TIB的原因可能
我尝试使用此代码访问Windows注册表:CRegKeykey;LPTSTRszBuffer=newTCHAR[50];ULONGcchBuffer=257;key.Open(HKEY_CURRENT_USER,L"HARDWARE",KEY_READ);ULONGchars;CStringstr;if(key.QueryStringValue(L"Test",0,&chars)==ERROR_SUCCESS){key.QueryStringValue(L"Test",str.GetBuffer(chars),&chars);str.ReleaseBuffer();}key.Close
Windows8.1/IE11自定义url协议(protocol)困惑。启动后,应用程序被执行,然后浏览器中的url重定向到about:blank即使是Skype的协议(protocol)也是如此:ChatviaSkype我尝试了一些方法,例如使用iframe,document.location.href=u;结果很差。当链接位于iframe内时,这似乎有效,否则失败:testdocument.location.href='proto://datadatadata';有人知道如何在浏览器不重定向到about:blank的情况下启动协议(protocol)的应用程序吗?我现在将IE11视